我有一组ActiveRecord模型,我希望将其转换为CSV。我尝试研究像FasterCSV这样的gem,但它们似乎只适用于字符串和数组,而不适用于ActiveRecord模型。简而言之,我要转换:user1=User.firstuser2=User.lasta=[user1,user2]收件人:id,username,bio,email1,user1,user1bio,user1email1,user2,user2bio,user2email有没有简单的Rails方法可以做到这一点? 最佳答案 下面将所有用户的属性写入一个文件:C
我有一个数组,我想做一个散列,这样我就可以快速询问“数组中有X吗?”。在perl中,有一种简单(快速)的方法可以做到这一点:my@array=qw(123);my%hash;@hash{@array}=undef;这会生成一个哈希值,如下所示:{1=>undef,2=>undef,3=>undef,}我在Ruby中想到的最好的是:array=[1,2,3]hash=Hash[array.map{|x|[x,nil]}]给出:{1=>nil,2=>nil,3=>nil}是否有更好的Ruby方法?编辑1不,Array.include?这不是一个好主意。它慢。它在O(n)而不是O(1)中执行
如何在ruby中将散列转换为结构?鉴于此:h={:a=>1,:b=>2}我想要一个这样的结构:s.a==1s.b==2 最佳答案 如果您已经定义了一个结构,并且您想要使用散列实例化一个实例:Person=Struct.new(:first_name,:last_name,:age)person_hash={first_name:"Foo",last_name:"Bar",age:29}person=Person.new(*person_hash.values_at(*Person.members))=>#
这是我的哈希:tempData={"a"=>100,"here"=>200,"c"=>"hello"}我需要像下面这样的方法来访问散列键:tempData.a#100tempData.here#200 最佳答案 你可以把你的散列包在OpenStruct中:require'ostruct'tempData={"a"=>100,"here"=>200,"c"=>"hello"}os=OpenStruct.newtempDataos.a#=>100os.here#=>200如果你真的真的想要,你也可以猴子修补Hash类,但我建议不要这样做
对于网络编程,数字以字符串形式出现。但是to_i会将"5abc"转换为5并将"abc"转换为0,都是错误的答案。为了捕获这些,我写道:defnumber_or_nil(s)number=s.to_inumber=nilif(number.to_s!=s)returnnumberend是否有一种更简洁、更符合Ruby标准的方法来完成此转换并检测该字符串不是数字? 最佳答案 使用整数(字符串)如果字符串无法转换为整数,它将引发ArgumentError错误。Integer('5abc')#=>ArgumentError:invalidv
我正在尝试将Ruby中的全大写字符串转换为小写字符串,但每个单词的第一个字符都是大写。示例:将“我的字符串在这里”转换为“我的字符串在这里”。我知道我可以使用.downcase方法,但这会使所有内容都变成小写(“我的字符串在这里”)。我正在扫描文件中的所有行并进行此更改,那么是否有可以通过ruby使用的正则表达式来实现此目的?谢谢! 最佳答案 如果您正在使用Rails(您真正需要的只是ActiveSupport,它是Rails的一部分),您可以使用titleize:"MYSTRINGHERE".titleize#=>"MyStr
我正在编写一个使用Hpricot的爬虫。它从某个网页下载字符串列表,然后我尝试将其写入文件。编码有问题:"\xC3"fromASCII-8BITtoUTF-8我有在网页上呈现并以这种方式打印的项目:Développementstr.encoding返回UTF-8,因此force_encoding('UTF-8')没有帮助。我如何将其转换为可读的UTF-8? 最佳答案 您的字符串似乎被错误地编码了:"Développement".encode("iso-8859-1").force_encoding("utf-8")#=>"Dév
我想知道Rails中有什么方便的函数可以将带有负号的字符串转换为数字。例如-1005.32当我使用.to_f方法时,数字变为1005,忽略负号和小数部分。 最佳答案 .to_f是正确的方法。例子:irb(main):001:0>"-10".to_f=>-10.0irb(main):002:0>"-10.33".to_f=>-10.33也许您的字符串不包含常规的“-”(破折号)?或者破折号和第一个数字之间有空格吗?添加:如果您知道您的输入字符串是一个float的字符串版本,例如“10.2”,那么.to_f是进行转换的最好/最简单的方法
我正在使用ruby1.9.2我正在尝试解析包含一些法语单词(例如spécifié)的CSV文件,并将内容放入MySQL数据库中。当我从CSV文件中读取行时,file_contents=CSV.read("csvfile.csv",col_sep:"$")返回的元素是ASCII-8BIT编码的字符串(spécifié变为sp\xE9cifi\xE9),然后像“spécifié”这样的字符串没有正确保存到我的MySQL数据库中。YehudaKatz表示ASCII-8BIT实际上是“二进制”数据,这意味着CSV不知道如何读取适当的编码。所以,如果我尝试让CSV强制编码如下:file_cont
我有一个Ruby散列,它看起来像:{"id"=>"123","name"=>"test"}我想将其转换为:{:id=>"123",:name=>"test"} 最佳答案 hash={"apple"=>"banana","coconut"=>"domino"}Hash[hash.map{|k,v|[k.to_sym,v]}]#=>{:apple=>"banana",:coconut=>"domino"}@mu太短了:没看到“递归”这个词,但如果你坚持(以及防止不存在的to_sym,只是想提醒一下在Ruby1.81.to_sym==ni